Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(clustering): introduce incremental sync for clustering #13157

Merged
merged 163 commits into from
Oct 16, 2024
Merged

Conversation

dndx
Copy link
Member

@dndx dndx commented Jun 4, 2024

KAG-4865
KAG-2986
KAG-2987
KAG-3502
KAG-3258
KAG-5283

NOTE:

  • cluster_rpc now is on by default
  • cluster_incremental_sync now is off by default, we will continue to fix tests after this PR then turn it on.

Flaky (perhaps need rerun):

  • spec/02-integration/09-hybrid_mode/03-pki_spec.lua
  • spec/02-integration/02-cmd/14-vault_spec.lua
  • spec/03-plugins/09-key-auth/04-hybrid_mode_spec.lua

@dndx dndx force-pushed the feat/incremental branch 3 times, most recently from 88e177a to e64c085 Compare June 4, 2024 17:13
@dndx dndx force-pushed the feat/incremental branch 2 times, most recently from 856ca04 to 50528fd Compare August 7, 2024 03:27
@dndx dndx force-pushed the feat/incremental branch from 50528fd to 2163b2b Compare August 19, 2024 08:27
@dndx dndx changed the title [WIP] incremental sync PoC Incremental sync PoC Sep 11, 2024
@chronolaw chronolaw force-pushed the feat/incremental branch 2 times, most recently from a558f38 to b11e659 Compare September 24, 2024 08:44
kong/db/strategies/off/init.lua Outdated Show resolved Hide resolved
@chronolaw chronolaw changed the title Incremental sync PoC feat(clustring): introduce incremental sync for clustering Sep 26, 2024
@chronolaw chronolaw changed the title feat(clustring): introduce incremental sync for clustering feat(clusteriing): introduce incremental sync for clustering Sep 26, 2024
@chronolaw chronolaw marked this pull request as ready for review September 30, 2024 08:17
@chronolaw chronolaw requested a review from chobits September 30, 2024 08:18
chronolaw and others added 23 commits October 16, 2024 21:28
* fix(tests): enable inc sync for 01-sync_spec.lua

* fix(incremental): dont delete old entity from LMDB if we clear it already

* dont modify crud type even though we dont delete old entity from lmdb

* localize ns_delta.wipe

* localize ns_delta.wipe - part 2

* fix that cp will not init clustering

* refactor old_entity logic

* cp should always support full sync protocol

* Revert "cp should always support full sync protocol"

This reverts commit 68039586ffdb5cc386df4d3eea5b4676972d9440.

* Revert "fix that cp will not init clustering"

This reverts commit b84f2618e3c721ae6c04df006735f371a8a9d9db.

* Revert "fix(tests): enable inc sync for 01-sync_spec.lua"

This reverts commit 54d0f54343c727f08352a72f80429b64069b6c0f.

---------

Co-authored-by: chronolaw <[email protected]>
@dndx dndx force-pushed the feat/incremental branch from 0df05a4 to 7c02759 Compare October 16, 2024 13:29
@dndx dndx merged commit 398e180 into master Oct 16, 2024
30 checks passed
@dndx dndx deleted the feat/incremental branch October 16, 2024 14:15
@team-gateway-bot
Copy link
Collaborator

Cherry-pick failed for master, because it was unable to cherry-pick the commit(s).

Please cherry-pick the changes locally.

git remote add upstream https://github.com/kong/kong-ee
git fetch upstream master
git worktree add -d .worktree/cherry-pick-13157-to-master-to-upstream upstream/master
cd .worktree/cherry-pick-13157-to-master-to-upstream
git checkout -b cherry-pick-13157-to-master-to-upstream
ancref=$(git merge-base 9ae36382db4b9485f8889b8cd80d66a0885c86e7 7c027596914938766d7c93d74406f894dc19aa96)
git cherry-pick -x $ancref..7c027596914938766d7c93d74406f894dc19aa96

@github-actions github-actions bot added the incomplete-cherry-pick A cherry-pick was incomplete and needs manual intervention label Oct 16, 2024
@kikito kikito removed the incomplete-cherry-pick A cherry-pick was incomplete and needs manual intervention label Oct 17, 2024
lhanjian pushed a commit that referenced this pull request Dec 23, 2024
* Revert "fix(rpc): disable cluster_rpc for 3.7"

This reverts commit ddda6a1.

This commit introduces a freshly redesigned DB-less mode that is more efficient
when storing data, more efficient when accessing data and incrementally update
able.

This commit also introduces the "incremental sync" RPC server/client. It
introduces the `kong.sync.v2` RPC capability that is used by CP to notify
new version updates to DP and for DP to pull config delta. DP applies these
config delta into the LMDB incrementally and transactionally which avoids
the expensive config flip and cache wipe majority of the time.

This commit also modifies the DAO so that for the CP,
config diff logs are generated transactionally whenever entity modification occurs.

Finally, this commit modifies the `off` strategy so that it works with the redesigned
DB-less mode and storage format.

Incremental sync is not yet enabled by default, it can be enabled by setting
`cluster_incremental_sync = on` via `kong.conf`.

KAG-4865
KAG-2986
KAG-2987
KAG-3502
KAG-3258
KAG-5283

---------

Co-authored-by: Chrono <[email protected]>
Co-authored-by: Xiaochen Wang <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

10 participants